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System and Method for Common Code Generation 



[0001] This application claims the benefit of U.S. 
Provisional Patent Application 60/186,560 filed on March 2, 2000 
and entitled "Method and System for Modular Software Architecture 
for Peer-to-Peer Management of Network Devices" and is expressly 
incorporated herein, in its entirety, by reference. 
Additionally, the application entitled "System and Method for a 
Command Structure Representation" to the named inventors Lee 
Chang and Shawn-Lin Dzeng, filed on an even date herewith and the 
application entitled "System and Method for Automatic Software 
Code Generation' 7 to the named inventors Lee Cheng and Shawn-Lin 
Dzeng, filed on an even date herewith, both of which are assigned 
to the Assignee of the present application, are expressly 
incorporated herein, in their entirety, by reference. 

BACKGROUND INFORMATION 

[0002] A variety of computing platforms exist in today's 
computing environment (e.g., UNIX, DOS, MAC, Windows 3.x, Windows 
9x, Windows NT, Palm) . Even more computing platforms are being 
developed' and will be developed in the future. This wide variety 
of computing platforms may present problems for software 
developers, for example, requiring software developers to provide 
users with software programs compatible with the existing 
computing platforms. 

[0003] Requiring compatibility of the software programs 
with multiple computing platforms often creates a number of 
problems for software developers. For example, developers may 
need to utilize programmers skilled in a variety of computing 
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platforms. Different programmers working on the same software 
program may generate code that works differently on different 
computing platforms. It is especially hard to ensure that the 
code is identical to each other since the code may be written in 
different languages for different computing platforms. 

[0004] Developing software programs compatible with 
several platforms may significantly increase the cost of these 
programs and extend the time required to bring the program to 
market. Also, there may be more expenses and difficulty to 
update such software programs . 

[0005] Another problem with existing technologies is that 
they often utilize data files or data structures in binary format 
to generate output files for a variety of computing platforms. 
The binary format may cause problems as the processing units of 
different computing platforms may encode numbers in different 
byte orders (e.g., Motorola processors may encode numbers 
differently than Intel processors) , requiring special flags and 
corresponding code to compensate for these differences. In 
addition, data files in binary structure form are fixed in size, 
requiring special fields and code to accept changes in content . 
Including formatting rules as part of each data file allows 
validation information to be contained therein in a form 
consistent with each specific version of the file. Otherwise, 
special efforts must be made to continuously update consistency 
checks in differing modules. Having data in an extendible format 
compensates for version skew in older project files and older 
programs. Otherwise, special efforts must be made to compensate 
for unexpected new fields and missing fields that have been 
deprecated. 
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[0006] Thus, there is a need for a system and method that 
simplifies the process of creating software programs for a 
variety of existing computing platforms or, for example, of 
developing code generation on different platforms intended for 
the target platform. 

SUMMARY OF THE INVENTION 

[0007] The present invention relates to a system and 
method improves a process of creating software programs for a 
variety of existing computing platforms. In particular, a 
developer receives an input file. The developer generates a 
formatted data file as a function of the input file. In the 
input file includes data, the data contained within the formatted 
data file is stored in a predetermined format compatible with 
each of a plurality of computing platforms. Then the developer 
generates a common generation file using a predetermined 
programming language which is a lowest common denominator 
language utilized by each of the plurality of computing 
platforms. The common generation file is capable of creating a 
predefined output file compatible with each of the plurality of 
computing platforms. The formatted data file is modified to 
create a modified formatted data file; the modification are 
provided via an interface of a corresponding one of the plurality 
of computing platforms. Finally, the common generation file is 
compiled with the modified data file to generate the predefined 
output file for the corresponding platform. Another exemplary 
method is where the developer provides the user with several 
development programs, each working in a different computer 
platform, with which creates the data that is then passed to the 
common code generation file/module internal to the program. 
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BRIEF DESCRIPTION OF DRAWINGS 

[0008] Figure 1 shows an exemplary embodiment of a system 
according to the present invention; 

Figure 2 shows a schematic diagram of a code -generation 
process; 

Figure 3 shows an exemplary method according to the present 
invention; and 

Figure 4 shows an exemplary embodiment of a modification 
step of the method illustrated in Figure 3 . 

DETAILED DESCRIPTION 

[0009] The present invention may be further understood 
with reference to the following description and the appended 
drawings, wherein like elements are provided with the same 
reference numerals. Throughout this specification, the exemplary 
embodiments of the present invention will be discussed with 
reference to embedded devices and the accompanying operating 
systems. However, those skilled in the art will understand that 
the present invention is not limited to embedded systems, and may 
be used with any computing system. Additionally, the term 
developer is generally used throughout this description to 
describe the individual responsible for developing the operating 
system (e.g., adding new commands, editing existing commands, 
etc.) The term user is generally used to describe the individual 
that may be using the operating system. However, the terms may 
be used interchangeably throughout this description. For 
example, the term user may also describe the individual 
responsible for developing the operating system. 

[0010] Figure 1 depicts a company 10 which sells and/or 
makes available a software application to users 20, 21, 22 and 
23 . As part of this software application, the company 10 may 
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need to provide certain data regarding different resources for 
use therewith. These resources may be a plurality of objects, 
tables, etc. For example, the company 10 may want to provide to 
users 20-23 a tree description of a particular product, a Simple 
Network Managed Protocol ("SNMP") table and a managed object 
abstract representation of the users' objects (e.g., anything 
that may need to be visible to the outside world) . 

[0011] The users 20-23 may be utilizing different 
platforms. For example, user 20 may be using a UNIX platform, 
user 21 may be utilizing a DOS platform, while users 22 and 23 
may be utilizing Windows NT and Windows 9x platforms, 
respectively. These computing platforms have different 
input/output interfaces, e.g., UNIX and DOS may have console 
interfaces, while the Windows NT and Windows 9x platforms may 
have graphical user interfaces ("GUIs"). 

[0012] The company 10 requests a developer 15 to develop 
a software application which has input/output interfaces 
compatible with the various users' platforms. The method and 
system according to the present invention allows an improvement 
in this process. In particular, according to the present 
invention, code generation is separated as a specialized function 
by creating a single module that can be used by a variety of 
development tools for a plurality of computing platforms which 
have different levels of user interfaces (e.g., the GUI, a 
command line console interface, etc.). As described below, this 
is achieved by (1) isolating code generation routines into 
language modules that are in a lowest common compatible language 
(e.g., language H C" ) ; (2) defining a common system- independent 
data format to represent and convey the data from any parent 
program to the code generation module; and (3) compiling the code 
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generation module into each program, insuring that output results 
are identical . 

[0013] Figures 2 and 3 show the method according to the 
present invention. In step 100, the company 10 provides a raw 
input file 40 to the developer 15. The raw input file 40 may- 
include any type of data, for example, data regarding attributes 
of the resources which are going to be provided to users 20-23* 
In alternative exemplary embodiment of the present invention, the 
raw input file 40 may be a blank file containing no data. In 
this case, the data is built up in a progressive manner. 

[0014] The developer 15 generates a formatted data file 
42 based on the raw data file 40 (step 102) . The formatted data 
file 42 has a predetermined format which is common (i.e., cross 
computing platform compatible) to any of the users 7 platforms. 
Such pi at form- independent format may be, for example, an XML 
file, an ASCII file, a binary file, etc. The formatted data file 
42 has a predetermined structure to store the data. In other 
words, the data may be structured so that new data fields can be 
added and old ones removed, and yet the data as a whole is still 
readable by older programs from any computing platform. The 
formatted data file 42 is structured such that rules for 
formatting the data are included or implied so that the data can 
be validated (e.g., XML) . If the raw input file 40 is a blank 
file, then the formatted data file 42 has no data, but may 
include information about its data structure. 

[0015] In step 104, shown in Figure 3, the developer 15 

writes a code generation file 46. The code generation file 46 
may be written using a lowest common denominator language which 
can be utilized by the computing platforms with which the 
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software application is to operate. One way to choose such a 
language is to examine each of the computing platforms involved 
and determine a language that may be understood by all of these 
computing platforms. For example, languages such as PASCAL and C 
may be understood by a variety of existing computing platforms. 
Thus, these- languages may serve as the lowest common denominator 
languages for many applications. This lowest common denominator 
language also should be able to process files without necessarily 
displaying any messages to the user. In addition, this language 
should be compatible with other programs of the computing 
platforms . 

[0016] The code generation file 46 is programmed to 
generate a file accessible by each of the computing platforms. 
As an input, the code generation file 46 accepts data saved in a 
structured form. For example, the code generation file 46 may 
accept the name of the modified data file 42', its structure and 
a desired type of computing platform. The creation of modified 
data file 42 1 is described in greater details below. 
Furthermore, the code generation file 46 may read/write data from 
the formatted data file 42. Any modification to the data may be 
saved into the formatted data file 42 by the code generation file 
46. One of the advantages of utilizing the code generation file 
46 is that it ensures that any modifications to the data are 
preserved in its formatted structure. 

[0017] In an alterative exemplary embodiment of the 
present invention, interpretation languages (such as TCL and 
BASIC) or plat form- independent languages (such as Java) may be 
used instead of the lowest common denominator languages (such as 
PASCAL and C) , in which the common code generation file/module 
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accessible using the corresponding computing platform. For 
example, the output file 50 may be accessed using GUIs if it was 
created for the Windows 9x platform. The output files 50 for 
different computing platforms may be created parallel and 
simultaneously . 

[0022] One of the advantages of the present invention is 
that the code generation file 46 needs to be prepared only once 
by a single developer and it is capable of generating an output 
file 50 for any desired computing platform . In other words, the 
present invention allows a developer to maintain the code 
generation function 46 as a separate module thus insuring that 
each version of the output data file for each of the computing 
platforms is identical. 

£0023] Furthermore, a single change of the modified 
formatted data file 42 ' may change the output file 50 for each of 
the desired computing platforms. Thus, the need to individually 
create an output file 50 for each computing platform is 
eliminated. The present invention also allows an automatically 
coordinative generation for output files for different computing 
platforms. 

[0024] As described below, the present invention may be 
utilized where there are two different computing platforms A and 
B. In particular, a computing platform A may utilize the GUI 
interface W and a command line interface X for code generation 
development, while computing system B, utilizes a proprietary GUI 
interface Y and a proprietary command line interface Z for code 
development . 



[0025] 



In conventional systems, the developer would need 
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to prepare four files-- one of which is compatible with a 
respective one of interfaces W # X, Y and Z. However, the present 
invention allows a developer to utilize the same data file to 
generate a formatted data file which can be edited via the 
interfaces W, X, Y and Z. Since each of the four interfaces may 
utilize the same identical code generation file to generate an 
output data file which is identified for both computing platforms 
A and B. Thus, the present invention allows the use of a common 
formatted data file and code generation file to produce an 
identical output data file regardless of the type of computing 
platform or user interface employed by these computing platforms. 

[0026] Those skilled in the art will understand that 
these techniques may be used for variety of computer hardware 
platforms. For example, the present invention may be utilized to 
generate code for chips manufactured by different hardware 
manufacturers . 

[0027] There are many modifications to the present 
invention which will be apparent to those skilled in the art 
without departing form the teaching of the present invention. 
The embodiments disclosed herein are for illustrative purposes 
only and are not intended to describe the bounds of the present 
invention which is to be limited only by the scope of the claims 
appended hereto. 
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CLAIMS 

What is claimed is: 

1. A method comprising the steps of: 

(a) receiving an input file; 

(b) generating a formatted data file as a function of the 
input file; 

(c) generating a common generation file using a 
predetermined programming language, the predetermined programming 
language being a lowest common denominator language utilized by 
each of a plurality of computing platforms, the common generation 
file adapted to create a predefined output file compatible with 
each of the plurality of computing platforms ; 

(d) receiving information to modify the formatted data file 
to create a modified formatted data file; and 

(e) compiling the- common generation file with the modified 
data file to generate the predefined output file for the 
corresponding platform. 

2. The method according to claim 1, wherein the lowest common 
denominator language processes files without displaying a message 
to a user. 

3. The method according to claim 1, wherein the lowest 
denominator language is one of C, C++ and PASCAL. 

4. The method according to claim 1, wherein the formatted data 
file is one of an ASCII text file, an XML file and a binary file. 

5. The method according to claim 1, wherein the compiling step 
is performed simultaneously for each of the plurality of 
computing platforms. 
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6. The method according to claim 1, further comprising the 
substep of adding, during the modification step, a field to the 
formatted data file by the code generation file. 

7. The- method according to claim 1, further comprising the 
substep of removing, during the modification step, a field from 
the formatted data file by the code generation file. 

8. The method according to claim 1, wherein step (d) includes 
the following substeps : 

reading the data according to the predetermined format by 
the code generation file, 

extracting the data from the formatted data file by the code 
generation file, 

receiving modifications to the data by the code generation 
file from an interface of the corresponding computing platform; 

storing by the code generation file the modified data into 
the modified data file in accordance with the predetermined 
format . 

9. The method according to claim 8, wherein the interface 
includes a command line interface. 

10. The method according to claim 8, wherein the interface 
includes a graphical user interface . 

11. The method according to claim 1, wherein the input file 
includes data. 

12. The method according to claim 1, wherein the input file is a 
blank file. 
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13. The method according to claim 11 , wherein the step (b) 
includes the substep of: 

formatting the data with a predetermined format compatible 
with each of a plurality of computing platforms. 

14. The method according to- claim 12, wherein the formatted data 
file is a blank file with a predetermined format compatible with 
each of a plurality of computing platforms to generate into a 
blank . 

15. A system, comprising: 
a memory arrangement; 

an input device receiving an input file; and 

a generation unit processor generating a formatted data file 
as a function of the input file, the processor generating a 
common generation file using a predetermined programming 
language, the predetermined programming language being a lowest 
common denominator language utilized by each of the plurality of 
computing platforms, the common generation file being capable of 
creating a predefined output file compatible with a corresponding 
one of the plurality of computing platforms, the processor 
modifying the formatted data file with the code generation file 
to create a modified data file using an interface of a 
corresponding computing platform of the plurality of computing 
platforms, the processor compiling the common generation file 
with the modified data file to generate the predefined output 
file for the corresponding platform. 

16. The system according to claim 15, wherein the input device 
includes data. 

17. The system according to claim 16, wherein the data is stored 
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in a predetermined format compatible with a plurality of 
computing platforms to generate the formatted data file. 

18. A computer- readable storage medium storing a set of 
instructions, the set of instructions capable of being executed 
by a processor, the set of instructions performing the steps of: 
(a) receiving an input file; 

(b) generating a formatted data file as a function of the 
input file; 

(c) generating a common generation file using a 
predetermined programming language, the predetermined programming 
language being a lowest common denominator language utilized by 
each of the plurality of computing platforms, the common 
generation file being capable of creating a predefined output 
file compatible with each of the plurality of computing 
platforms; 

(d) modifying the formatted data file to create a modified 
formatted data file, the modification being provided via an 
interface of a corresponding one of the plurality of computing 
platforms; and 

(e) compiling the common generation file with the modified 
data file to generate the predefined output file for the 
corresponding platform. 
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Figure 2 
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may be written. 

[0018] In step 106, the developer 15 modifies the 
formatted data file 42 to create a modified data file 42 1 . The 
modifications may be done in a variety of ways depending on the 
computing platform that is being used. An exemplary modification 
of the formatted data file 42 is described below and is shown in 
Figure 4 . 

[0019] First, the developer 15 indicates his intention to 
modify the data stored in the formatted data file 42 (step 2 00) . 
Then the data is extracted from the formatted data file 42 
according to the predetermined data structure by the code 
generation file 46 (step 202). Depending on the computing 
platform being utilized, the developer 15 may modify the data 
(step 204) . If the developer 15 utilizes a computing platform 
such as Windows NT, the developer 15 may modify the data via the 
GUI and/or a command line (step 206) . If on the other hand, the 
user is utilizing a platform such as DOS, the user may modify the 
data using the console by entering modifications via a command 
line only (step 2 08) . 

[0020] The modifications are received and processed by 
the code generation file 46. In particular, the modifying data 
is translated into the same platform- independent format (step 
210) . Subsequently, the code generation file 46 saves the data 
into the modified formatted data file 42 1 in accordance with the 
predetermined data structure (step 212) . 



[0021] In step 108, the code generation file 46 is 
compiled with the modified formatted data file 42 1 to generate a 
predefined output file 50. The predefined output file 50 may be 



